Automated updates of software and systems

ABSTRACT

These and other objectives are attained with a method and system for updating software applications or systems on a target client. The method comprises the steps of providing the target client with an update manager; and using the update manager to initiate a procedure to compare the level of software or services on the target client with the level of software or services available on a specified server to determine if an update is available on the server for the software or services on the target client. If an update is available, the update is copied from the server to the target client. Preferably, the update manager registers with the server manger to have a specified one or more of the applications or systems updated. The preferred embodiment of the invention uses information that currently exists with the customer and vendor that can make the update process ore automated.

BACKGROUND OF THE INVENTION

[0001] 1. Field of the Invention

[0002] This invention generally relates to updating software and operating systems. More specifically, the invention relates to the automatic updating of software and operating systems on a target, client system.

[0003] 2. Background Art

[0004] Software and operating systems are constantly being updated with new features or with fixes to solve defects. The applications and systems can be updated with full product releases or with incremental releases.

[0005] Presently, customers that own applications and systems are required to get the updates and upgrade their software. The customer can get updates from a vendor, either electronically over the Internet, or physically on a CD tape, etc. In some cases, the customer must prove their entitlement to a software product or operating system before they are allowed to retrieve an update.

[0006] Customers can have multiple products residing on one machine from multiple vendors, and can have multiple platforms at their sites. Some products can update themselves, while others cannot. It would be highly desirable to provide customers with a solution that could provide updates for a single machine, or for their entire IT network. In addition, some IT networks are behind firewalls and require secure access to automatic updates.

SUMMARY OF THE INVENTION

[0007] An object of this invention is to provide automated electronic software updates and services for systems and applications across disparate platforms.

[0008] Another object of the present invention is to create a layer, between a target and a host with the updates, that controls the updating of applications and systems without having to have the technology embedded into a product.

[0009] A further object of the invention is to provide a business intelligence for software updates and services that acts as a middle layer, or director, between a target system and a host that stores updates.

[0010] Another object of the invention is to provide an environment in which a client and a server can interact with mutual assurance that their transactions are secure.

[0011] These and other objectives are attained with a method and system for updating software applications or systems on a target client. The method comprises the steps of providing the target client with an update manager, and using the update manager initiate a procedure to compare the level of software or services on the target client with the level of software or services available on a specified server to determine if an update is available on the server for the software or services on the target client. If an update is available, the update is copied from the server to the target client. Preferably, the update manager registers with the server manger to have a specified one or more of the applications or systems updated.

[0012] The above-mentioned procedure that is initiated by the update manager to compare the level of software, may be performed by the server, or alternatively, this procedure may be performed by the update manager or the update manager and the server may work together to perform this procedure. Also, the preferred embodiment of the invention uses information that currently exists with the customer and vendor that can make the update process more automated. In particular, customers know (or the information exists in their systems) what software levels they have installed, and the vendor knows what they are entitled to. Instead of requiring the customer to access a site, determine if an update is available, then locate the update, and provide entitlement information, the preferred embodiment of the present invention provides a procedure that knows enough about the customers and their system or systems to navigate finding and retrieving an update on their behalf.

[0013] Further benefits and advantages of the invention will become apparent from a consideration of the following detailed description, given with reference to the accompanying drawings, which specify and show preferred embodiments of the invention.

BRIEF DESCRIPTION OF THE DRAWINGS

[0014]FIG. 1 illustrates the present invention and the process flows between the client and an update server.

[0015]FIG. 2 illustrates an alternate embodiment of the invention in which a tiered model is provided to support closed infrastructures.

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

[0016] With reference to FIG. 1, in the preferred operation of the present invention, a user 10 registers for the update services for a specific product. A user 10 can register for multiple products on multiple platforms. A client 12 is used to check periodically if an update is available. This is done by having the client 12 send information about the target system 14, and what is installed on it, to a host 16 for comparison. The client provides knowledge of the environment to provide updated content back to the customer 10.

[0017] If an update exists, the user is notified that an update is available. The user can then select to have a director 20 retrieve the update using the proper credentials to identify the user and the target product to update. The director 20 then notifies the user 10 that the update has been retrieved and is ready to be installed. The director 20 controls the amount of data that needs to be shipped by the host by only shipping what is needed to the target.

[0018] More specifically, a customer 10 registers for an automated update service through a portal. Updates can include upgrades, services or publications. A certificate 22 is returned for each service. Customer information is stored at site 24. A module may be added onto director 20 to handle a specific platform. If needed, that module is downloaded and added.

[0019] Director 20 periodically checks for updates to registered products. Service and product availability are based on certificates 22. System checks system inventory for synchronization. System configuration is sent to server 16.

[0020] If an update is available, a notification is sent to the customer 10 informing him or her of the new update. If the customer wishes to, he or she can launch system 16 and send an automatic update request. Any necessary customer information, it may be noted, is already stored. If multiple updates are available, the customer can select individual ones to update.

[0021] Director 20 places an order for an upgrade, and the director periodically checks for a completed order. If the order is ready and the customer operating system 12 is validated, a ticket 24 is issued for the order and sent back to the client 12.

[0022] Director 20 notifies server 16 to retrieve the order. The ticket 24 sent to server 14 will automatically keep retrying in case of interrupted transfer until the download is completed. Once download is complete, a message is sent back to notify the customer 10. Customers can initiate installation through director 20 or by their own computer system.

[0023] The user 10 can configure director 20 to have various degrees of automation, with multiple checkpoints or none. In this way, the present invention can be used as a policy director for managing updates. For instance, as illustrated in FIG. 2, system architecture can be separated into a customer part 30 or “shop,” and a service provider part 32, and with these two parts communicating with each other via a service broker 34.

[0024] The preferred embodiment of the invention, as described above, provides a number of important advantages. The invention effectively addresses the problem of providing automatic updating of software and operating systems on a target, client system by creating a layer between the product installed on a client's system and the developer of the product. A program, installed on the client's system, can query the installed products and levels, and communicates that information to a server that can determine if an update is available. By solving the problem in this way, the product itself does not have to be modified to look for updates.

[0025] While it is apparent that the invention herein disclosed is well calculated to fulfill the objects stated above, it will be appreciated that numerous modifications and embodiments may be devised by those skilled in the art, and it is intended that the appended claims cover all such modifications and embodiments as fall within the true spirit and scope of the present invention. 

1. A method of updating software applications or systems on a target client, comprising the steps of: providing the target client with an update manager; using the update manager to initiate a procedure to compare the level of software or services on the target client with the level of software or services available on a specified server to determine if an update is available on the server for the software or services on the target client; and if an update is available, copying the update from the server to the target client.
 2. A method according to claim 1, further comprising the step of the update manager registering with the server manger to have a specified one or more of the applications or systems updated.
 3. A method according to claim 2, further comprising the step of maintaining on the server a list identifying, for each of a set of clients, the updates to which the client is entitled.
 4. A method according to claim 3, wherein: the using step includes the step of, if the update manager determines that a particular update is available for one of the applications or services on the target client, the update manager sending to the server a request for said particular update; in response to receiving said request, the server checking said list to determine if the target client is entitled to said particular update; and the copying step includes the step of copying the particular update from the server to the target client only if the target client is entitled to said particular update.
 5. A method according to claim 4, wherein: the step of sending to the server a request for said particular update includes the step of, the update manager issuing a certificate authenticating the type of service stored on the target client; and the copying step includes the step of the server issuing to the target client a ticket for said particular update.
 6. A method according to claim 1, wherein the step of using the update manager includes the step of using the update manager to check, at defined times, for updates on the server to applications or services on the target client.
 7. A system for updating software applications or systems on a target client, comprising: an update manager located on the target client, and including means to initiate a procedure to compare the level of software or services on the target client with the level of software or services available on a specified server to determine if an update is available on the server for the software or services on the target client; and means on said server for copying the update from the server to the target client if the update is available.
 8. A system according to claim 7, the update manager includes means for registering with the server manger to have a specified one or more of the applications or systems on the target client updated.
 9. A system according to claim 8, wherein the server includes mans for maintaining a list identifying, for each of a set of clients, the updates to which the client is entitled.
 10. A system according to claim 9, wherein: if the update manager determines that a particular update is available for one of the applications or services on the target client, the update manager sends to the server a request for said particular update; in response to receiving said request, the server checks said list to determine if the target client is entitled to said particular update; and the server copies the particular update from the server to the target client only if the target client is entitled to said particular update.
 11. A system according to claim 10, wherein: the update manager issues to the server a certificate authenticating the type of services stored on the target client; and the means for copying includes means for issuing to the target client a ticket for said particular update.
 12. A system according to claim 7, wherein the update manager includes means to check, at defined times, for updates on the server to applications or services on the target client.
 13. A program storage device readable by machine, tangibly embodying a program of instructions executable by the machine to perform method steps for updating software applications or systems on a target client, said method steps comprising: using an update manager on the target client to initiate a procedure to compare the level of software or services on the target client with the level of software or services available on a specified server to determine if an update is available on the server for the software or services on the target client; and if an update is available, copying the update from the server to the target client.
 14. A program storage device according to claim 13, wherein said method steps further comprise the step of using the update manager to register with the server to have a specified one or more of the applications or systems updated.
 15. A program storage device according to claim 14, wherein said method steps further comprise the step of maintaining on the server a list identifying, for each of a set of clients, the updates to which the client is entitled.
 16. A program storage device according to claim 15, wherein: the using step includes the step of, if the update manager determines that a particular update is available for one of the applications or services on the target client, using the update manager to send to the server a request for said particular update; in response to receiving said request, the server checking said list to determine if the target client is entitled to said particular update; and the copying step includes the step of copying the particular update from the server to the target client only if the target client is entitled to said particular update.
 17. A program storage device according to claim 16, wherein: the step of sending to the server a request for said particular update includes the step of, using the update manager to issue a certificate authenticating the type of service stored on the target client; and the copying step includes the step of using the server to issue to the target client a ticket for said particular update.
 18. A program storage device according to claim 13, wherein the step of using the update manager includes the step of using the update manager to check, at defined times, for updates on the server to applications or services on the target client. 